How to add MVC to your ASP.NET Core web application
You’ve seen how to create your first simple web application using just the command line.
Now let’s add MVC to the picture.
Start off by bringing in the ASP.NET and MVC package dependencies.
As with all dependencies, you’ll need to ensure they’ve been downloaded using the restore command.
dotnet restore
You’re all set to configure your web application to use MVC, meaning you can start defining routes, using controllers and views.
Add a sprinkling of MVC#
For MVC to spring into life, you need to make some changes to startup.cs.
There are two important steps here.
.NET Core automatically uses Microsoft’s latest framework for dependency injection (hence the Microsoft.Extensions.DependencyInjection
dependency). This provides a simple mechanism to register the services which your application needs.
Inside of the ConfigureServices
method you can register any services (dependencies) that your application requires. In this case you’re registering all the services needed in order to use Microsoft’s implementation of MVC.
app.UseMvc()
tells your app to add MVC to the request execution pipeline. This will ensure that all requests to your web application are routable to the MVC framework, meaning you can use controllers, views and anything else contained within the MVC implementation (action filters etc).
Throw in a controller#
So far so good, but if you run your app you’ll still only see “Hello world”, so how do you start using MVC?
Well, unsurprisingly you’ll need a controller. In ASP.NET Core your controllers can live anywhere, meaning you don’t have to stick to a Controllers folder if you don’t want to. But old habits die hard so let’s keep it simple for now.
In a command prompt, change to your app’s folder then create a new Controllers folder and HomeController.cs.
(In case you don’t recognise it, that last command creates a new empty file).
Now add the following to your controller.
Attribute Routing is probably the simplest way to get started and means you can stay focused on building your features whilst tweaking the routing to something that makes sense for your specific app.
Is it data? is it a View? No it’s an ActionResult#
ASP.NET Core doesn’t differentiate between MVC and Web API controllers, so you can return views or data using the same approach.
In this example you’ve returned a simple string. You can just as easily return an object as data.
The Greeting
class in this case is a simple affair with a Username
property.
If you haven’t already, run your application again.
dotnet run
Take a look at the results in your browser to see your very own personalised greeting as a JSON response.
Take in the view#
If you want to return a view, that’s simple too.
Modify your controller’s index action to return a view instead.
By convention, Core will look in a few places to find a view with the same name as the action, in this case Index.cshtml.
Create a Views/Home
folder in the root of your app and add an index.cshtml.
At this point, if you try and go to /home/index you’ll get a nasty shock, nothing will appear, just a blank page.
Before you tear your hair out trying to work out why, let me save you the hassle. There are two more steps you need to take.
Firstly, Core will attempt to compile the razor views at runtime and fails unless you add the preserveCompilationContext property to your csproj file.
preserveCompilationContext
ensures that various reference assemblies (e.g. System) are preserved so that Core can compile your razor views at runtime.
Secondly, you need to tell your Core app where to start looking for content files (e.g. views). You can specify this by setting the UseContentRoot()
option in Program.cs
.
To make sure these changes take effect, you may need to run the following command.
dotnet clean
Before the usual dotnet run
command.
This ensures that the previously compiled output (typically bin\debug) is cleared and rebuilt and will save you from hours of head-scratching, trying to work out why your changes haven’t worked (ask me how I know).
Try hitting the page again now and you will see your rendered view.
And finally#
So just to wrap this up, let’s add some dynamic data to your view.
Modify your controller to return your greeting object.
A simple change to your view and your page will offer you a friendly greeting (defaulting to “you” if a name is not specified in the request).
In Summary#
Apart from one or two gotchas (looking at you preserveCompilationContext
), extending your web application to use MVC is simply a matter of configuration.
In fact, much of what you’ll want to do with .NET Core, even completely changing the way your application works is a matter of knowing what’s available and then tweaking the configuration.
All posts in ASP.NET Core from scratch using the command line
- Your first .NET Core web application using just the command line (in ten minutes or less)
- Add Web API to your .NET Core application
- How to add MVC to your ASP.NET Core web application
- Compile your changes on the fly with .NET Core Watch
- The basics of publishing your .NET Core web app
- How to serve static files for your Single Page Application from .NET Core
- Troubleshoot your ASP.NET Core web app using logging
- How to log different levels of information in your ASP.NET Core app
- Start using Dependency Injection with ASP.NET Core